repo.or.cz
/
and.git
/
blob
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
log
|
graphiclog1
|
graphiclog2
|
commit
|
commitdiff
|
tree
|
refs
|
edit
|
fork
blame
|
history
|
raw
|
HEAD
ACM ICPC::Regional Warmup 1 (Easy version) + Algunos cambios en el manual
[and.git]
/
Mi manual de algoritmos
/
version_maraton_interuniversitaria_2008-2
/
src
/
number_theory
/
bigmod.cpp
blob
3d63b5548df3c7bc6639f9c77af7ed86b9b265c0
1
//retorna (b^p)mod(m)
2
// 0 <= b,p <= 2147483647
3
// 1 <= m <= 46340
4
long
f
(
long
b
,
long
p
,
long
m
){
5
long
mask
=
1
;
6
long
pow2
=
b
%
m
;
7
long
r
=
1
;
8
9
while
(
mask
){
10
if
(
p
&
mask
)
11
r
= (
r
*
pow2
) %
m
;
12
pow2
= (
pow2
*
pow2
) %
m
;
13
mask
<<=
1
;
14
}
15
return
r
;
16
}